Add _gtk_box_get_children() internal function
authorCarlos Garcia Campos <carlosgc@gnome.org>
Mon, 26 Jul 2010 13:24:15 +0000 (15:24 +0200)
committerCarlos Garcia Campos <carlosgc@gnome.org>
Thu, 5 Aug 2010 07:51:15 +0000 (09:51 +0200)
https://bugzilla.gnome.org/show_bug.cgi?id=625300

gtk/gtkbbox.c
gtk/gtkbox.c
gtk/gtkbox.h
gtk/gtkstatusbar.c

index 582e4470468964ad4efc27e46e3db9512beee8e7..1720d726b6454da852df5c44fa1d0f4ac3282874 100644 (file)
@@ -457,7 +457,7 @@ _gtk_button_box_child_requisition (GtkWidget *widget,
 
   nchildren = 0;
   nsecondaries = 0;
-  list = children = gtk_container_get_children (GTK_CONTAINER (bbox));
+  list = children = _gtk_box_get_children (GTK_BOX (bbox));
   needed_width = child_min_width;
   needed_height = child_min_height;  
   ipad_w = ipad_x * 2;
@@ -790,7 +790,7 @@ gtk_button_box_size_allocate (GtkWidget     *widget,
         childspace = child_height + childspacing;
       }
 
-  list = children = gtk_container_get_children (GTK_CONTAINER (box));
+  list = children = _gtk_box_get_children (GTK_BOX (box));
 
   while (children)
     {
index c372a1d149ea91b16e686548a330122552aa36db..84c28de3d69108916542594936b97dd0be624968 100644 (file)
@@ -1770,3 +1770,27 @@ gtk_box_forall (GtkContainer *container,
        (* callback) (child->widget, callback_data);
     }
 }
+
+GList *
+_gtk_box_get_children (GtkBox *box)
+{
+  GtkBoxPriv *priv;
+  GtkBoxChild *child;
+  GList *children;
+  GList *retval = NULL;
+
+  g_return_val_if_fail (GTK_IS_BOX (box), NULL);
+
+  priv = box->priv;
+
+  children = priv->children;
+  while (children)
+    {
+      child = children->data;
+      children = children->next;
+
+      retval = g_list_prepend (retval, child->widget);
+    }
+
+  return g_list_reverse (retval);
+}
index 0a17af2e2b19fc26229ea76b3149cd817b18daa6..85a2f4a4cb11f6b17bea67fe958ebbda90a5dfcf 100644 (file)
@@ -109,6 +109,7 @@ void        _gtk_box_set_old_defaults   (GtkBox         *box);
 gboolean    _gtk_box_get_spacing_set    (GtkBox         *box);
 void        _gtk_box_set_spacing_set    (GtkBox         *box,
                                          gboolean        spacing_set);
+GList      *_gtk_box_get_children       (GtkBox         *box);
 
 G_END_DECLS
 
index f6972f99b0b2a15cc484a690925a4bcd0542ee97..ded06208c6df5f148c2c58ba5632ed2657dc4eb1 100644 (file)
@@ -1034,13 +1034,14 @@ has_extra_children (GtkStatusbar *statusbar)
   GtkPackType child_pack_type, frame_pack_type;
   GtkWidget *child, *frame;
   GList *l, *children;
+  gboolean retval = FALSE;
 
   /* If the internal frame has been modified assume we have extra children */
   if (gtk_bin_get_child (GTK_BIN (priv->frame)) != priv->label)
     return TRUE;
 
   frame = NULL;
-  children = gtk_container_get_children (GTK_CONTAINER (statusbar));
+  children = _gtk_box_get_children (GTK_BOX (statusbar));
   for (l = children; l; l = l->next)
     {
       frame = l->data;
@@ -1063,12 +1064,15 @@ has_extra_children (GtkStatusbar *statusbar)
                                    NULL, NULL, NULL, &child_pack_type);
 
       if (frame_pack_type == GTK_PACK_START || child_pack_type == GTK_PACK_END)
-       return TRUE;
+        {
+         retval = TRUE;
+         break;
+       }
     }
 
   g_list_free (children);
 
-  return FALSE;
+  return retval;
 }
 
 static void